---
title: Sheet
description: Extends the Dialog component to display content that complements the main content of the screen.
component: true
kobalte:
    link: https://kobalte.dev/docs/core/components/dialog
    api: https://kobalte.dev/docs/core/components/dialog#api-reference
---

<ComponentPreview name="sheet-demo" />

## Installation

<Tabs defaultValue="cli">

<TabsList>
    <TabsTrigger value="cli">CLI</TabsTrigger>
    <TabsTrigger value="manual">Manual</TabsTrigger>
    <TabsIndicator class="bg-primary" />
</TabsList>

<TabsContent value="cli">

```bash
npx shadcn-solid@latest add sheet
```

</TabsContent>

<TabsContent value="manual">

<Steps>

<Step>Install the following dependencies:</Step>

```bash
npm install @kobalte/core
```

<Step>Copy and paste the following code into your project.</Step>

<ComponentSource name="sheet" />

<Step>Update the import paths to match your project setup.</Step>

</Steps>

</TabsContent>

</Tabs>

## Usage

```tsx
import {
    Sheet,
    SheetContent,
    SheetDescription,
    SheetHeader,
    SheetTitle,
    SheetTrigger,
} from "@/components/ui/sheet"
```

```tsx
<Sheet>
    <SheetTrigger>Open</SheetTrigger>
    <SheetContent>
        <SheetHeader>
            <SheetTitle>Are you sure absolutely sure?</SheetTitle>
            <SheetDescription>
                This action cannot be undone. This will permanently delete your
                account and remove your data from our servers.
            </SheetDescription>
        </SheetHeader>
    </SheetContent>
</Sheet>
```

## Examples

### Side

Use the `side` property to `<SheetContent />` to indicate the edge of the screen where the component will appear. The values can be `top`, `right`, `bottom` or `left`.

<ComponentPreview name="sheet-side" />

### Size

You can adjust the size of the sheet using CSS classes:

```tsx {3}
<Sheet>
    <SheetTrigger>Open</SheetTrigger>
    <SheetContent className="w-400px sm:w-540px">
        <SheetHeader>
            <SheetTitle>Are you sure absolutely sure?</SheetTitle>
            <SheetDescription>
                This action cannot be undone. This will permanently delete your
                account and remove your data from our servers.
            </SheetDescription>
        </SheetHeader>
    </SheetContent>
</Sheet>
```
